package com.example.lotterysystem.dao.handler;

import cn.hutool.crypto.SecureUtil;
import cn.hutool.crypto.symmetric.AES;
import com.example.lotterysystem.dao.dataobject.Encrypt;
import org.apache.catalina.security.SecurityUtil;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import org.apache.ibatis.type.MappedJdbcTypes;
import org.apache.ibatis.type.MappedTypes;
import org.springframework.util.StringUtils;

import java.nio.charset.StandardCharsets;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

//被处理的类型
@MappedTypes(Encrypt.class)
//转换后的jdbc类型
@MappedJdbcTypes(JdbcType.VARCHAR)
public class EncryptTypeHandler extends BaseTypeHandler<Encrypt> {


    //密钥
    private final byte[] KEY = "123456789abcdefg".getBytes(StandardCharsets.UTF_8);


    /**
     * 设置参数
     * @param ps  SQL预编译对象
     * @param i     需要赋值的索引位置
     * @param parameter     原本位置 i 需要赋的值
     * @param jdbcType      jdbc类型
     * @throws SQLException
     */
    @Override
    public void setNonNullParameter(PreparedStatement ps, int i, Encrypt parameter, JdbcType jdbcType) throws SQLException {
        if(parameter == null || parameter.getValue() == null){
            ps.setString(i, null);
            return;
        }
        System.out.println("加密的内容：" + parameter.getValue());
        //加密
        AES aes = SecureUtil.aes(KEY);
        String str = aes.encryptHex(parameter.getValue());
        ps.setString(i, str);
    }


    /**
     * 获取值的相关方法
     * @param rs        结果集
     * @param columnName        索引名
     * @return
     * @throws SQLException
     */
    @Override
    public Encrypt getNullableResult(ResultSet rs, String columnName) throws SQLException {
        System.out.println("获取值得到的加密内容：" + rs.getString(columnName));
        return dencrypt(rs.getString(columnName));
    }


    /**
     * 获取值的相关方法
     * @param rs    结果集
     * @param columnIndex       索引位置
     * @return
     * @throws SQLException
     */
    @Override
    public Encrypt getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
        System.out.println("获取值得到的加密内容：" + rs.getString(columnIndex));
        return dencrypt(rs.getString(columnIndex));
    }


    /**
     * 获取值的相关方法
     * @param cs        结果集
     * @param columnIndex       索引位置
     * @return
     * @throws SQLException
     */
    @Override
    public Encrypt getNullableResult(CallableStatement cs, int columnIndex) throws SQLException {
        System.out.println("获取值得到的加密内容：" + cs.getString(columnIndex));
        return dencrypt(cs.getString(columnIndex));
    }


    /**
     * 解密
     * @param str
     * @return
     */
    private Encrypt dencrypt(String str){
        if(!StringUtils.hasText(str)){
            return null;
        }
        return new Encrypt(SecureUtil.aes(KEY).decryptStr(str));
    }
}
